(function(undefined) {
    'use strict';
    describe('VideoPlayer Events plugin', function() {
        var state, oldOTBD, Logger = window.Logger;

        beforeEach(function() {
            oldOTBD = window.onTouchBasedDevice;
            window.onTouchBasedDevice = jasmine
                .createSpy('onTouchBasedDevice')
                .and.returnValue(null);

            state = jasmine.initializePlayer();
            spyOn(Logger, 'log');
            spyOn(state.videoEventsPlugin, 'getCurrentTime').and.returnValue(10);
        });

        afterEach(function() {
            $('source').remove();
            window.onTouchBasedDevice = oldOTBD;
            state.storage.clear();
            if (state.videoPlayer) {
                state.videoPlayer.destroy();
            }
        });

        it('can emit "load_video" event', function() {
            state.el.trigger('ready');
            expect(Logger.log).toHaveBeenCalledWith('load_video', {
                id: 'id',
                code: 'html5'
            });
        });

        it('can emit "play_video" event when emitPlayVideoEvent is true', function() {
            state.videoEventsPlugin.emitPlayVideoEvent = true;
            state.el.trigger('play');
            expect(Logger.log).toHaveBeenCalledWith('play_video', {
                id: 'id',
                code: 'html5',
                currentTime: 10
            });
            expect(state.videoEventsPlugin.emitPlayVideoEvent).toBeFalsy();
        });

        it('can not emit "play_video" event when emitPlayVideoEvent is false', function() {
            state.videoEventsPlugin.emitPlayVideoEvent = false;
            state.el.trigger('play');
            expect(Logger.log).not.toHaveBeenCalled();
        });

        it('can emit "pause_video" event', function() {
            state.el.trigger('pause');
            expect(Logger.log).toHaveBeenCalledWith('pause_video', {
                id: 'id',
                code: 'html5',
                currentTime: 10
            });
            expect(state.videoEventsPlugin.emitPlayVideoEvent).toBeTruthy();
        });

        it('can emit "speed_change_video" event', function() {
            state.el.trigger('speedchange', ['2.0', '1.0']);
            expect(Logger.log).toHaveBeenCalledWith('speed_change_video', {
                id: 'id',
                code: 'html5',
                current_time: 10,
                old_speed: '1.0',
                new_speed: '2.0'
            });
        });

        it('can emit "seek_video" event', function() {
            state.el.trigger('seek', [1, 0, 'any']);
            expect(Logger.log).toHaveBeenCalledWith('seek_video', {
                id: 'id',
                code: 'html5',
                old_time: 0,
                new_time: 1,
                type: 'any'
            });
            expect(state.videoEventsPlugin.emitPlayVideoEvent).toBeTruthy();
        });

        it('can emit "play_video" event after "seek_video" event ', function() {
            state.videoEventsPlugin.emitPlayVideoEvent = false;
            state.el.trigger('seek', [1, 0, 'any']);
            expect(state.videoEventsPlugin.emitPlayVideoEvent).toBeTruthy();
        });

        it('can emit "stop_video" event', function() {
            state.el.trigger('ended');
            expect(Logger.log).toHaveBeenCalledWith('stop_video', {
                id: 'id',
                code: 'html5',
                currentTime: 10
            });
            expect(state.videoEventsPlugin.emitPlayVideoEvent).toBeTruthy();

            Logger.log.calls.reset();
            state.el.trigger('stop');
            expect(Logger.log).toHaveBeenCalledWith('stop_video', {
                id: 'id',
                code: 'html5',
                currentTime: 10
            });
            expect(state.videoEventsPlugin.emitPlayVideoEvent).toBeTruthy();
        });

        it('can emit "skip_video" event', function() {
            state.el.trigger('skip', [false]);
            expect(Logger.log).toHaveBeenCalledWith('skip_video', {
                id: 'id',
                code: 'html5',
                currentTime: 10
            });
        });

        it('can emit "do_not_show_again_video" event', function() {
            state.el.trigger('skip', [true]);
            expect(Logger.log).toHaveBeenCalledWith('do_not_show_again_video', {
                id: 'id',
                code: 'html5',
                currentTime: 10
            });
        });

        it('can emit "edx.video.language_menu.shown" event', function() {
            state.el.trigger('language_menu:show');
            expect(Logger.log).toHaveBeenCalledWith('edx.video.language_menu.shown', {
                id: 'id',
                code: 'html5'
            });
        });

        it('can emit "edx.video.language_menu.hidden" event', function() {
            state.el.trigger('language_menu:hide');
            expect(Logger.log).toHaveBeenCalledWith('edx.video.language_menu.hidden', {
                id: 'id',
                code: 'html5',
                language: 'en'
            });
        });

        it('can emit "show_transcript" event', function() {
            state.el.trigger('transcript:show');
            expect(Logger.log).toHaveBeenCalledWith('show_transcript', {
                id: 'id',
                code: 'html5',
                current_time: 10
            });
        });

        it('can emit "hide_transcript" event', function() {
            state.el.trigger('transcript:hide');
            expect(Logger.log).toHaveBeenCalledWith('hide_transcript', {
                id: 'id',
                code: 'html5',
                current_time: 10
            });
        });

        it('can emit "edx.video.closed_captions.shown" event', function() {
            state.el.trigger('captions:show');
            expect(Logger.log).toHaveBeenCalledWith('edx.video.closed_captions.shown', {
                id: 'id',
                code: 'html5',
                current_time: 10
            });
        });

        it('can emit "edx.video.closed_captions.hidden" event', function() {
            state.el.trigger('captions:hide');
            expect(Logger.log).toHaveBeenCalledWith('edx.video.closed_captions.hidden', {
                id: 'id',
                code: 'html5',
                current_time: 10
            });
        });

        it('can destroy itself', function() {
            var plugin = state.videoEventsPlugin;
            spyOn($.fn, 'off').and.callThrough();
            state.videoEventsPlugin.destroy();
            expect(state.videoEventsPlugin).toBeUndefined();
            expect($.fn.off).toHaveBeenCalledWith({
                'ready': plugin.onReady,
                'play': plugin.onPlay,
                'pause': plugin.onPause,
                'ended stop': plugin.onEnded,
                'seek': plugin.onSeek,
                'skip': plugin.onSkip,
                'speedchange': plugin.onSpeedChange,
                'language_menu:show': plugin.onShowLanguageMenu,
                'language_menu:hide': plugin.onHideLanguageMenu,
                'transcript:show': plugin.onShowTranscript,
                'transcript:hide': plugin.onHideTranscript,
                'captions:show': plugin.onShowCaptions,
                'captions:hide': plugin.onHideCaptions,
                'destroy': plugin.destroy
            });
        });
    });
}).call(this);
